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(57) Abstract: A video encoding scheme employs progressive fine -granularity layered coding to encode video data frames into 
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results in occasional fluctuations in the encoded image data. The video encoding scheme efficiently eliminates such fluctuations by 
predicting higher quality data from the lower quality data encoded in the base layer and a low quality enhancement layer. 
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SYSTEM AND METHOD WITH ADVANCE PREDICTED BIT-PLANE 
CODING FOR PROGRESSIVE FINE-GRANULARITY SCALABLE (PFGS) 

VIDEO CODING 

5 TECHNICAL FIELD 

This invention relates to systems and methods for coding video data, and 
more particularly, to motion-compensation-based video coding schemes that employ 
fine-granularity layered coding. 

10 BACKGROUND OF THE INVENTION 

Efficient and reliable delivery of video data is becoming increasingly 
important as the Internet continues to grow in popularity. Video is very appealing 
because it offers a much richer user experience than static images and text. It is 
more interesting, for example, to watch a video clip of a winning touchdown or a 

15 Presidential speech than it is to read about the event in stark print. Unfortunately, 
video data is significantly larger than other data types commonly delivered over the 
Internet. As an example, one second of uncompressed video data may consume one 
or more Megabytes of data. Delivering such large amounts of data over error-prone 
networks, such as the Internet and wireless networks, presents difficult challenges 

20 in terms of both efficiency and reliability. 

To promote efficient delivery, video data is typically encoded prior to 
delivery to reduce the amount of data actually being transferred over the network. 
Image quality is lost as a result of the compression, but such loss is generally 
tolerated as necessary to achieve acceptable transfer speeds. In some cases, the loss 

25 of quality may not even be detectable to the viewer. 
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Video compression is well known. One common type of video compression 
is a mdtion-compensation-based video coding scheme, which is used in such coding 
standards as MPEG-1, MPEG-2, MPEG-4, H.261, and H.263. 

One particular type of motion-compensation-based video coding scheme is 
5 fine-granularity layered coding. Layered coding is a family of signal representation 
techniques in which the source information is partitioned into a sets called "layers". 
The layers are organized so that the lowest, or "base layer", contains the minimum 
information for intelligibility. The other layers, called "enhancement layers", 
contain additional information that incrementally improves the overall quality of the 
10 video. With layered coding, lower layers of video data are often used to predict one 
or more higher layers of video data. 

The quality at which digital video data can be served over a network varies 
widely depending upon many factors, including the coding process and 
transmission bandwidth. "Quality of Service", or simply "QoS", is the moniker 
15 used to generally describe the various quality levels at which video can be 
delivered. Layered video coding schemes offer a range of QoSs that enable 
applications to adopt to different video qualities. For example, applications 
designed to handle video data sent over the Internet (e.g., multi-party video 
conferencing) must adapt quickly to continuously changing data rates inherent in 
20 routing data over many heterogeneous sub-networks that form the Internet. The 
QoS of video at each receiver must be dynamically adapted to whatever the current 
available bandwidth happens to be. Layered video coding is an efficient approach 
to this problem because it encodes a single representation of the video source to 
several layers that can be decoded and presented at a range of quality levels. 
25 Apart from coding efficiency, another concern for layered coding techniques 

is reliability. In layered coding schemes, a hierarchical dependence exists for each 
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of the layers. A higher layer can typically be decoded only when ail of the data for 
lower layers or the same layer in the previous prediction frame is present. If 
information at a layer is missing, any data for the same or higher layers is useless. 
In network applications, this dependency makes the layered encoding schemes very 
5 intolerant of packet loss, especially at the lower layers. If the loss rate is high in 
layered streams, the video quality at the receiver is very poor. 

Fig. 1 depicts a conventional layered coding scheme 20, known as "fine- 
granularity scalable" or "FGS". Three frames are shown, including a first or 
intraframe 22 followed by two predicted frames 24 and 26 that are predicted from 
10 the intraframe 22. The frames are encoded into four layers: a base layer 28, a first 
layer 30, a second layer 32, and a third layer 34. The base layer typically contains 
the video data that, when played, is minimally acceptable to a viewer. Each 
additional iayer contains incrementally more components of the video data to 
enhance the base layer. The quality of video thereby improves with each additional 
15 layer. This technique is described in more detail in an article by Weiping Li, 
entitled "Fine Granularity Scalability Using Bit-Plane Coding of DCT 
Coefficients", ISO/IEC JTC1/SC29/WG1 1, MPEG98/M4204 (December 1998). 

With layered coding, the various layers can be sent over the network as. 
separate sub-streams, where the quality level of the video increases as each sub- 
20 stream is received and decoded. The base-layer video 28 is transmitted in a well- 
controlled channel to minimize error or packet-loss. In other words, the base layer 
is encoded to fit in the minimum channel bandwidth. The goal is to deliver and 
decode at least the base layer 28 to provide minimal quality video. The 
enhancement 30-34 layers are delivered and decoded as network conditions allow to 
25 improve the video quality (e.g., display size, resolution, frame rate, etc.). In 
addition, a decoder can be configured to choose and decode a particular portion or 
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subset, of these layers to get a particular quality according to its preference and 
capability. 

One characteristic of the illustrated FGS coding scheme is that the 
enhancement layers 30-34 are predictively coded from the base layer 28 in the 
5 reference frames. As shown in Fig. 1 ? each of the enhancement layers 30-34 in the 
predicted frames 24 and 26 can be predicted from the base layer of the preceding 
frame. In this example, the enhancement layers of predicted frame 24 can be 
predicted from the base layer ofintraframe 22. Similarly, the enhancement layers of 
predicted frame 26 can be predicted from the base layer of preceding predicted 
10 frame 24. 

The FGS coding scheme provides good reliability in terms of error recovery 
from occasional data loss. By predicting all enhancement layers from the base 
layer, loss or corruption of one or more enhancement layers during transmission can 
be remedied by reconstructing the enhancement layers from the base layer. For 

15 instance, suppose that frame 24 experiences some error during transmission. In this 
case, the base layer 28 of preceding intraframe 22 can be used to predict the base 
layer and enhancement layers of frame 24. , 

Unfortunately, the FGS coding scheme ha§ a significant drawback in that the 
scheme is very, inefficient from a coding or compression standpoint since the 

20 prediction is always based on the lowest quality base layer. Accordingly, there 
remains a need for a layered coding scheme that is efficient without sacrificing 
error recovery. 

Fig. 2 depicts another conventional layered coding scheme 40 in which three 
frames are encoded using a technique introduced in an article by James Macnicol, 
25 Michael Frater and John Arnold, which is .entitled, "Results on Fine Granularity 
Scalability", ISO/IEC JTC1/SC29AVG1 1, MPEG99/m5 122 (October 1999). The 
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three frames include a i Irst frame 42, followed by two predicted frames 44 and 46 
that are predicted from he first frame 42. The frames are encoded into four layers: 
a base layer 48, a first layer 50, a second layer 52, and a third layer 54. In this 
scheme, each layer in a frame is predicted from the same layer of the previous 
5 frame. For instance, the enhancement layers of predicted frame 44 can be predicted 
from the corresponding layer of previous frame 42. Similarly, the enhancement 
layers of predicted frame 46 can be predicted from the corresponding layer of 
previous frame 44. 

The coding scheme illustrated in Fig. 2 has the advantage of being very 
10 efficient from a coding perspective. However, it suffers from a serious drawback in 
that it cannot easily recover from data loss. Once there is an error or packet loss in 
the enhancement layers, it propagates to the end of a GOP (group of predicted 
frames) and causes serious drifting in higher layers in the prediction frames that 
follow. Even though there is sufficient bandwidth available later on, the decoder is 
1 5 not able to recover to the highest quality until an other GOP start. 

Accordingly, there remains a need for an efficient layered video coding 
scheme that adapts to bandwidth fluctuation and also exhibits good error recovery 
characteristics. 

20 SUMMARY OF THE INVENTION - 

A video encoding scheme employs progressive fine-granularity scalable 
(PFGS) layered coding to encode video data frames into multiple layers, including a 
base layer of comparatively low quality video and multiple enhancement layers of 
increasingly higher quality video. Some of the enhancement layers in a current 
25 frame are predicted from at least one same or lower quality layer in a reference 
frame, whereby the lower quality layer is not necessarily the base layer. 
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In one described implementation,, a video encoder encodes frames of video 
data into multiple layers, including a base layer and multiple enhancement layers. 
The base layer contains minimum quality video data and the enhancement layers 
contain increasingly higher quality video data. Layers in a prediction frame are 
5 predicted from both the base layer and one or more enhancement layers. 

Residues resulting from the image frame prediction are defined as the 
difference between the original image and predicted image. When using a linear 
transform, such as Discrete Cosine Transform (DCT), the coefficients of the 
predicted residues equal the differences between the DCT coefficients of the 

10 original image and the DCT coefficients of the predicted image. Since the PFGS 
coding scheme uses multiple reference layers for the prediction, the coding scheme 
produces multiple sets of predicted DCT coefficients. The predicted DCT 
coefficients range in quality depending upon what reference layer is used for the 
prediction. Lower quality predicted DCT coefficients (or "LQPD") are produced 

15 by using lower quality reference layers, such as the base layer. Higher quality 
predicted DCT coefficients (or fc< HQPD") are produced by using higher quality 
enhancement layers as reference. 

The expectation is that the HQPD coefficients will produce lower DCT 
residues in comparison to the LQPD coefficients because the reference layer is of 

20 higher quality and hence closer ;tp the original image. Lower DCT residues 
translate into fewer coding layers, .thereby resulting in better coding efficiency. 
While the expectation is valid from a mean value perspective, the various qualities 
of DCT residues tend to fluctuate due to the motion between frames and other 
reasons. In some instances, individual DCT residues in the HQPD coefficients 

25 actually increase \ry comparison, to DCT. residues produced by referencing a lower 
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quality layer (i.e., residues in the LQPD coefficients). The undesired fluctuations 

and increases result in less efficient coding. 

Ideally, to eliminate the fluctuations in the DCT coefficients caused by using 

multiple prediction references of different quality, the HQPD coefficients should be 
5 part of or partial encoded into the base layer and low enhancement layers. 

However, in practice, only die lower quality LQPD coefficients are encoded in the 

base layer and low enhancement layers. 

The video encoding scheme described herein efficiently eliminates these 

fluctuations by predicting HQPD coefficients from the LQPD coefficients encoded 
10 in the base layer and low quality enhancement layer. These predicted HQPD 

coefficients, or high quality residues derived therefrom, can be calculated both in 

encoder and in decoder. Except for any residues from the HQPD prediction that 

still exceed the maximum, the bitstream containing the base layer and low quality 

enhancement layer need not be modified. The use of predicted HQPD coefficients 
1 5 improves coding efficiencies by eliminating large fluctuations prior to encoding. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The same numbers are used throughout the drawings to reference like 
elements and features. 

20 Fig. 1 is a diagrammatic illustration of a prior art layered coding scheme in 

which all higher quality layers can be predicted from the lowest or base quality 
layer. 

Fig. 2 is a diagrammatic illustration of a prior art layered coding scheme in 
which frames are predicted from their corresponding quality layer components in 
25 the intraframe or reference frame. 
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Fig. 3 is a block diagram of a video distribution system in which a content 
producer/provider encodes video data and transfers the encoded video data over a 
network to a client. 

Fig. 4 is diagrammatic illustration of a layered coding scheme used by the 
5 content producer/provider, to encode the video data. 

Fig. 5 is similar to Fig. 4 and further shows how the number of layers that 
are transmitted over a network can be dynamically changed according to bandwidth 
availability. 

Fig. 6 is similar to Fig. 4 and further shows how missing or error- infested 
1 0 layers can be reconstructed from a reference layer in a reconstructed frame. 

Fig. 7 is a diagrammatic illustration of a macroblock in a prediction frame 
predicted from a reference macroblock in a reference frame according to a motion 
vector. 

Fig. 8 is a flow diagram showing a method for encoding video data using the 
15 layered coding scheme illustrated in Fig. 4. 

Fig. 9 is a block diagram of an exemplary video encoder implemented at the 
content producer/provider. 

Fig. 10 is a flow diagram showing a method for encoding video data that is 
implemented by the video encoder of Fig. 9. 
20 Fig. 11 is a diagrammatic illustration of an exemplary original low quality 

predicted DCT coefficients to be -encoded. • 

Fig. 12 is a diagrammatic illustration of the Fig. 11 layer following 
quantization. v v. 

Fig. 13 is a diagrammatic; illustration of the multiple enhancement layers 
25 used to encode residues resulting from' a difference between the coefficients in the 
Fig. 11 layer and the Fig. 12 layer. 
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Fig. 14 is a diagrammatic illustration a set of coefficients that are encoded in 
the base layer and first enhancement layer. 

Fig. 15 is a diagrammatic illustration of a set of residues resulting from the 
difference between the coefficients of the Fig. 11 layer and the Fig. 14 layer. 
5 Fig. 16 is a diagrammatic illustration of a layer that is predicted from a high 

quality image layer, such as an enhancement layer. 

Fig. 17 is a diagrammatic illustration of a set of residues resulting from the 
difference between the coefficients of the Fig. 16 layer and the Fig. 14 layer. 

Fig. 18 is a diagrammatic illustration of quantization levels implemented by 
10 a uniform threshold quantizer. 

Fig. 19 is a block diagram of another exemplary video encoder implemented 
at the content producer/provider. 

Fig. 20 is a block diagram of an exemplary video decoder implemented at 
the client, which is complementary to the video encoder of Fig. 19. 
15 Fig. 21 is a block diagram of yet another exemplary video encoder 

implemented at the content producer/provider. 

Fig. 22 is a block diagram of another exemplary video decoder implemented 

at the client, which is complementary to the video encoder of Fig. 21. 

Fig. 23 is a flow diagram of a video coding process implemented by the 

20 video encoders of Figs. 19 and 21. 

PETAflj;D EMBODIMENT 

This disclosure describes a layered video coding scheme used in motion- 
cornpensation-based video coding systems and methods. The coding scheme is 
described in the context of delivering video data over a network, such as the 
25 Internet or a wireless network. However, the layered video coding scheme has 
general applicability to a wide variety of environments. 
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Exemplary System Architecture 

Fig. 3 shows a video distribution system 60 in which a content 
producer/provider 62 produces and/or distributes video over a network 64 to a 
5 client 66. The network is representative of many different types of networks, 
including the Internet, a LAN (local area network), a WAN (wide area network), a 
SAN (storage area network), and wireless networks (e.g., satellite, cellular, RF, 
etc.). 

The content producer/provider 62 may be implemented in many ways, 

10 including as one or more server computers configured to store, process, and 
distribute video data. The content producer/provider 62 has a video storage 70 to 
store digital video files 72 and a distribution server 74 to encode the video data and 
distribute it over the network 64. The server 74 has a processor 76, an operating 
system 78 (e.g., Windows NT, Unix, etc.), and a video encoder 80. The video 

15 encoder 80 may be implemented in software, firmware, and/or hardware. The 
encoder is shown as a separate standalone module for discussion purposes, but may 
be constructed as part of the processor 76 or incorporated into operating system 78 
or other applications (not shown). 

The video encoder. 80 encodes the video data 72 using a motion- 

20 compensation-based coding scheme. More specifically, the encoder 80 employs a 
progressive fine-granularity scalable (PFGS) layered coding scheme. The video 
encoder 80 encodes the video into multiple layers, including a base layer and one or 
more enhancement layers. : t Tine-granulanty v coding, means that the difference 
between any two layers, even if small, can be used by the decoder to improve the 

25 image quallity, : Fine-granularity layered video coding, makes sure that the 
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prediction of a next video frame from a lower layer of the current video frame is 
good enough to keep the efficiency of the overall video coding. 

The video encoder 80 has a base layer encoding component 82 to encode the 
video data into the base layer and an enhancement layer encoding component 84 to 
5 encode the video data into one or more enhancement layers. The video encoder 
encodes the video data such that some of the enhancement layers in a current frame 
are predicted from at least one same or lower quality layer in a reference frame, 
whereby the lower quality layer is not necessarily the base layer. The video encoder 
80 may also include a bit-plane coding component 86 that predicts data in higher 

10 enhancement layers. Various implementations of the video encoder 80 are 
described below in more detail with reference to Figs. 9, 19, and 21. 

The client 66 is equipped with a processor 90, a memory 92, and one or more 
media output devices 94. The memory 92 stores an operating system 96 (e.g., a 
Windows-brand operating system) that executes on the processor 90. The operating 

15 system 96 implements a client-side video decoder 98 to decode the layered video 
streams into the original video. In the event data is lost, the decoder 98 is capable 
of reconstructing the missing portions of the video from frames that are successfully 
transferred. The client-side video decoder 98 has a base layer decoding component 
95, an enhancement layer decoding component 97, and optionally a bit-plane 

20 coding component 99. Various implementations of the video encoder 80 are 
diescribed below in more detail wiih reference to Figs. 20, and 22. 

Following decoding, the client stores the video in memory and/or plays the 
video via the media output devices 94. The client 26 may be embodied in many 
different ways, including a computer, a handheld entertainment device, a set-top 

25 box, a television, an Application Specific Integrated Circuits (ASIC) and so forth. 
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Exemplary PFGS Layered Coding Scheme 

As noted above, the video encoder 80 encodes the video data into multiple 
layers, such that some of the enhancement layers in a current frame are predicted 
from at least one same or lower quality, layer, in a reference frame that is not 
5 necessarily the base layer. There are many ways to implement this FPGS layered 
coding scheme. One example is illustrated in Fig. 4 for discussion purposes and to 
point out the advantages of the scheme. 

Fig. 4 conceptually illustrates a PFGS layered coding scheme 100 
implemented by the video encoder 80 of Fig. 3. The encoder 80 encodes frames of 

10 video data into multiple layers, including a base layer and multiple enhancement 
layers. For discussion purposes, Fig. 4 illustrates four layers: a base layer 102, a 
first layer 104, a second layer 106, and a third layer 108. The upper three layers 
104-108 are enhancement layers to the base video layer 102. The term layer here 
refers to a spatial layer or SNR (quality layer) or both. Five consecutive frames are 

15 illustrated for discussion purposes. 

For every inter frame, the original image is compensated by referencing a 
previous base layer and one enhancement layer to form the predicted image. 
Residues resulting from the prediction are defined as the difference between the 
original image and the predicted image. As an example, one linear transformation 

20 used to transform the original image is a Discrete Cosine Transform (DCT). Due to 
its linearity, the DCT coefficients of predicted residues equal the differences 
between DCT coefficients of the original image and the DCT coefficients of 
predicted image. . . : . ; ...... ........... 

The number of layers produced by the PFGS layered coding, scheme is not 

25 fixed, but instead is based on the number of .layers needed to encode the residues. 
For instance, assume that a maximum residue can be represented in binary format 
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by five bits. In this case five enhancement layers are used to encode such residues, 
a first layer to code the most significant bit, a second layer to code the next most 
significant bit, and so on. 

With coding scheme 1 00, higher quality layers are predicted from at least 
5 one same or lower quality layer, but not necessarily the base layer. In the illustrated 
example, except for the base-layer coding, the prediction of some enhancement 
layers in a prediction frame (P- frame) is based on a next lower layer of a 
reconstructed reference frame. Here, the even frames are predicted from the even 
layers of the preceding frame and the odd frames are predicted from the odd layers 

1 0 of the preceding frame. For instance, even frame 2 is predicted from the even 

layers of preceding frame 1 (i.e., base layer 102 and second layer 106). The layers 
of odd frame 3 are predicted from the odd layers of preceding frame 2 (i.e., the first 
layer 104 and the third layer 106). The layers of even frame 4 are once again 
predicted from the even layers of preceding frame 3. This alternating pattern 

15 continues throughout encoding of the video bitstream. In addition, the correlation 
between a lower layer and a next higher layer within the same frame can also be 
exploited to gain more coding efficiency. 

The scheme illustrated in Fig. 4 is but one of many different coding schemes. 
It exemplifies a special case in a class of coding schemes that is generally 

20 represented by the following relationship: 

L mod N - i mod M 

where L designates the layer, N denotes a layer group depth, z designates the frame, 
25 and M denotes a frame group depth. Layer group depth defines how many layers 
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may refer back to a common reference layer. Frame group depth refers to the 
number of frames or period that are grouped together for prediction purposes. 

The relationship is used conditionally for changing reference layers in the 
coding scheme. If the equation is true, the layer is coded based on a lower 
5 reference layer in the preceding reconstructed frame. 

The relationship for the coding scheme in Fig. 4 is a special case when both 
the layer and frame group depths are two. Thus, the relationship can be modified to 
L mod N = i mod because N = M. In this case where A/==A/=2, when frame / is 2 
and layer L is 1 (i.e., first layer 104), the value L mod VV does not equal that of / mod 
10 /V, so the next lower reference layer (i.e., base layer 102) of the reconstructed 
reference frame 1 is used. When frame / is 2 and layer L is 2 (i.e., second layer 
1 06), the value L mod N equals that of i mod TV, so a higher layer (i.e., second 
enhancement layer 106) of the reference frame is used. 

Generally speaking, for the case where Af=A-/=2, this relationship holds that 
15 for even frames 2 and 4, the even layers (i.e., base layer 102 and second layer 106) 
of preceding frames 1 and 3, respectively, are used as reference; whereas, for odd 
frames 3 and 5, the odd layers (i.e., first layer 104 and third layer 108) of preceding 
frames 2 and 4, respectively, are used as reference. 

The above coding description is yet a special case of a more general case 
20 where in each frame the prediction layer used can be randomly assigned as long as a 
prediction path from lower layer to higher layer is maintained across several frames. 

The coding scheme affords high coding efficiency along with good error 
recovery. The proposed coding scheme is particularly beneficial when applied to 
video transmission over the Internet and wireless channels. One advantage is that 
25 the encoded bitstream can adapt to the available bandwidth of the channel without a 
drifting problem. 
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Fig. 5 shows an example of this bandwidth adaptation property for the same 
coding scheme 100 of Fig. 4. A dashed line 1 10 traces the transmitted video layers. 
At frames 2 and 3, there is a reduction in bandwidth, thereby limiting the amount of 
data that can be transmitted. At these two frames, the server simply drops the 
5 higher layer bits (i.e., the third layer 108 is dropped from frame 2 and the second 
and third layers 106 and 108 are dropped from frame 3). However after frame 3, 
the bandwidth increases again, and the server transmits more layers of video bits. 
By frame 5, the decoder at the client can once again obtain the highest quality video 
layer. 

10 Another advantage is that higher video layers, which may not have 

successfully survived transmission or may have contained an error, may be 
recovered from lower layers after a number of preset frames. Fig. 6 shows an 
example in which the third and fourth layers of frame 3 are not correctly received at 
the receiving client. In this case, the third layer 106 of frame 3 may be 
15 reconstructed in part from the first layer 104 of preceding reference frame 2, as 
represented by the dashed arrow. As a result, there is no need for any re-encoding 
and re-transmission of the video bitstream. All layers of video are efficiently coded 
and embedded in a single bitstream. 

Another advantage of the coding scheme is that it exhibits a very nice error 
20 resilience property when used for coding macroblocks. In error-prone networks 
(e.g., the Internet, wireless channel, etc.), packet loss or errors are likely to occur 
and sometimes quite often. How to gracefully recover from these packet losses or 
errors is a topic for much active research. With the layered coding scheme 100 of 
Fig. 4, it can be shown that as long as the base layer 102 does not have any packet 
25 loss or error, the packet losses/errors in the higher layers can always be gracefully 
recovered over a few frames without any re-transmission and drifting problem. 
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Fig. 7 shows an example in which a motion vector 120 of a macroblock 
(MB) 122 in a prediction frame points to a reference macroblock 124 in a reference 
frame. The reference MB 124 does not necessarily align with the original MB 
boundary in the reference frame. In a worst case, the reference MB 124 consists of 
5 pixels from four neighboring MBs 126, 128, 130, and 132 in the reference frame. 

Now, assume that some of the four neighboring MBs 126-132 have 
experienced packet loss or error, and each of them has been reconstructed to the 
maximum error free layer. For example, MBs 126-132 have been reconstructed at 
layers Ml, M2, M3, and M4, respectively. The reference MB 124 is composed by 
10 pixels, from the reconstructed four neighboring MBs 126-132 in the reference frame 
at a layer equal , to the minimum of the reconstructed layers, (i.e., 
min(Ml,M2,M3,M4)). As a result, the MB 122 being decoded in the prediction 
frame is decoded at a maximum layer equal to: 

15 1 +min(MUM2,M3,M4) 

As a result, no drifting error is introduced and an error- free frame is 
reconstructed over a few frames depending on the number of layers used by the 
encoder. 

20 Fig. 8 shows a general layered coding process implemented at the server-side 

encoder 80 and client-side decoder 98. The process may be implemented in 
hardware and/or software. The process is described with reference to Fig. 3. 

At step 150, the encoder 80 encodes each macroblock in a reference or 
intraframe (or "I-frame") into different layers, With reference to Fig. 4, suppose 

25 that frame 1 is an I-frame,, and the encoder 80 forms the base, and three 
enhancement layers 102-108, At step 152, the encoder 80 encodes each predicted 
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frame (or "P-frame") in o different layers. Suppose that frame 2 is a P-frame. The 
encoder 80 encodes tte base layer 102 of frame 2 according to conventional 
techniques and encodes the enhancement layers 104-108 of frame 2 according to 
the relationship L mod N — / mod M. 
5 At step 154, the encoder evaluates whether there are any more P-frames in 

the group of P-frames (GOP). If there are (i.e., the "yes" branch from step 154), the 
next P-frame is encoded in the same manner. Otherwise, all P-frames for a group 
have been encoded (step 156). 

The process continues until all I-frames and P-frames have been encoded, as 

10 represented by the decision step 158. Thereafter, the encoded bitstream can be 
stored in its compressed format in video storage 70 and/or transmitted from server 
74 over the network 64 to the client 66 (step 160). When transmitted, the server 
transmits the base layer within the allotted bandwidth to ensure delivery of the base 
layer. The server also transmits one or more enhancement layers according to 

15 bandwidth availability. As bandwidth fluctuates, the server transmits more or less 
of the enhancement layers to accommodate the changing network conditions. 

The client 66 receives the transmission and the decoder 98 decodes the I- 
frame up to the available layer that successfully made the transmission (step 162). 
The decoder 98 next decodes each macroblock in each P-frame up to the available 

20 layers (step 164). If one or more layers were not received or contained errors, the 
decoder 98 attempts to reconstruct the layer(s) from the lower layers of the same or 
previous frame(s) (step 166). The decoder decodes all P-frames and I-frames in the 
encoded bitstream (steps 168-172); At step 174, the client stores and/or plays the 
decoded bitstream. 

25 

Exemplary Video Encoder 
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. Fig. 9 shows an exemplary implementation of video encoder 80, which is 
used by server 74 to encode the video data files prior to distribution over the 
network 64 (Fig. 3). The video encoder 80 is configured to code video data 
according to the layered coding scheme illustrated in Fig. .4, where both the layer 

5 group depth TV and the frame group depth M equal nyo. 

Video encoder 80 has a base layer encoder 82 and an enhancement layer 
encoder 84, which are delineated by dashed boxes. It includes a frame separator 
202 that receives the video data input stream and separates the video data into 1- 
frames and P-frames. The P-frames are sent to a motion estimator 204 to estimate 

10 the movement of objects from locations in the I-frame to other locations in the P- 
frame. The motion estimator 204 also receives as reference for the current input, a 
previous reconstructed frame stored in frame memory 0 as well as reference layers 
with different SNR (signal-to-noise ratio) resolutions stored in frame memories 0 to 
n-1. . 

15 According to the coding scheme described above with respect to Fig. 4, the 

current layer is predicted from the next lower layer of a preceding reference 
reconstructed frame , to make the motion prediction as accurate as possible. For 
example, . enhancement layer j is predicted by layer j-1 of the reference 
reconstructed frame stored in frame memory j-L The motion estimator 204 outputs 

20 its results to motion compensator 206. The motion estimator 204 and motion 
compensator 206 are well-known components used in conventional MPEG 
encoding. 

In base layer coding, a, displaced frame difference (DFD) between the 
current input and base layer of the reference reconstructed frame is divided into 8x8 
25 blocks. A block k of the DFD image in the base layer at a time t is. given as 
follows: 
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A f t .o(k) = J2 !III /r A.yH,,o^-Ax,y-AK;|| 

x€block(k) y£biock(k) 

The result &f,,o(k} is an 8x8 matrix whose element is a residue from motion 
5 compensation,/^; is the original image at time t, and f,./, 0 (x.y) is a base layer of 
the reference reconstructed image at time M. The vector (Ax, Ay) is a motion 
vector of block k referencing to f t -i.o(x,y). 

The residual images after motion compensation are transformed by a DCT 
(Discrete Cosine Transform) module 208 and then quantified by a quantification 
10 function Q at module 210. The bitstream of the base layer is generated by 
translating the quantified DCT coefficients using a variable length table (VLT) 
212, as follows: 




VLT(Q(DCT(£f M0 (k)))) 



k 



15 

The base layers of the frames are also passed through a dequantization 
function Q" 1 at module 214. Accordingly, the dequantized DCT coefficients in the 
base layer are: 

20 Ko(k) = Qr 1 (Q q (DCT($\ 0 (k)))) 

The result R tt0 (k) is an 8x8 matrix, whose element is a DCT coefficient of 
^ft.ofk)- The DCT coefficients are passed to n frame memory stages. In all stages 
other than a base stage 0, the DCT coefficients are added to coefficients from the 
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enhancement layer encoder 84. The coefficients are then passed through inverse 
DCT (IDCT) modules 216(0), 216(1), 216(n-l) and the results are stored in 
frame memories 218(0), 218(1), 218(n-l). The contents of the frame memories 
218 are fed back to the motion estimator 204. 
5 With base layer coding, the residues of block k in the DCT coefficient 

domain are: 

AR, 0 (k) = DCT(Af tM (k))-R tt0 (k) . 

10 The enhancement layer encoder 84 receives the original DCT coefficients 

output from DCT module 208 and the quantified DCT coefficients from the 
quantizer module 210 and produces an enhancement bitstream. After taking 
residues of all DCT coefficients in an 8x8 block, the find reference module 220 
forms run length symbols to represent the absolute values of the residue. The 64 

15 absolute values of the residue block are arranged in a zigzag order into a one- 
dimensional array and stored in memory 222. A module 224 computes the 
maximum value of all absolute values as follows: 

m f^ max (AR t o(k)) 

20 

The minimum number of bits needed to represent the maximum value m in a 
binary format dictates the number of enhancement layers for each block. Here, 
there are n bit planes 226(1 )-226(n) that encode n enhancement layers using 
variable length coding (VLC). , - : r : 
25 Thejesidual signal of blpckJt.of the DFD image. in the enhancement layer at 

a time / is given as follows: 
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x 6 block(k) y6 Woc*W 



where 1 < i < n. The encoding in the enhancement layer is as follows: 



R ti (k) = R tj (k) 



The bracketed operation [*] is modular arithmetic based on a modulo value 
of 2 n ~\ After encoding the enhancement layer /, the residues in DCT coefficient 
10 domain are: 

A R tJ (k) - DCT(Af t Jk))^2 R tj W 



The bitstream generated in enhancement layer i is: 



15 



B,= ^ VLTf 



DCT(&fJk))-2j=tt.j( k ) 
j=o 



) 

2^' 



At time the summary value of DCT coefficient of block k, which is 
encoded in based layer and enhancement layers, is: 
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~>1 



sum(k) R u (V 



i.=0 



Fig. 1 0 shows an encoding process implemented by the video encoder of Fig. 

5 9. At step 300, the video encoder distinguishes between an I-frame and a P-frame. 
For I-frame encoding, the video encoder generates the corresponding bitstream and 
updates the various frame memories 218(0)-218(n-l ). For instance, the base layer 
is encoded and stored in frame memory 0 (steps 302 and 304). The enhancement 
layer. 1 is coded and stored in frame memory 1 (steps 306 and 308). This continues 

10 for all enhancement layers 1 to n, with the coding results of enhancement layer n-1 
being stored in frame memory n- 1 (steps 3 1 0, 3 1 2, and 3 1 4). 

For P-frame encoding, the video encoder performs motion compensation and 
transform coding. Both the base layer and first enhancement layer use the base 
layer in frame memory 0 as reference (steps 320 and 322). The coding results of 

15 these layers in the P-frame are also used to update the frame memory 0. The 
remaining enhancement layers in a P-frame use the next lower layer as reference, as 
indicated by enhancement layer 2 being coded and used to update frame memory 1 
(step 324) and enhancement layer n being coded and used to update frame memory 
n-1 (step 326). 

20 It is noted that the encoder of Fig. 9 and the corresponding process of Fig. 1 0 

depict it frame memories 21 8(0)-218(n-l) for purposes of describing the structure 
and clearly conveying how the layering is achieved. However, in implementation, 
the number of frame memories 218 can be reduced by almost one-half. In the 
coding scheme of Fig. 4, for even frames (e.g., frames 2 and 4). only the even layers 

25 of the previous frame (e.g., 2 nd layer 106 of frames 1 and 3) are used for prediction 
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and not the odd layers. Accordingly, the encoder 80 need only store the even layers 
of the previous frame into frame memories for prediction. Similarly, for odd 
frames (e.g., frames 3 and 5), the odd layers of the previous frame (e.g., 1 st and 3 rd 
layers 102 and 108 of frames 2 and 4) are used for prediction and not the even 
5 layers. Ax that time, the encoder 80 stores only the odd layers into the frame 
memories for prediction. Thus, in practice, the encoder may be implemented with 
nil frame buffers to accommodate the alternating coding of the higher enhancement 
layers. In addition, the encoder employs one additional frame memory for the base 
layer. Accordingly, the total number of frame memories required to implement the 
10 coding scheme of Fig. 4 is («-rl)/2. 

Potential Coding Inefficiencies Due To Prediction From Multiple 
Reference Layers 

In the PFGS layered coding scheme described above, images are predicted 
1 5 from the original image by referencing a base layer and an enhancement layer from 
a previous frame. In Fig. 4, the base and enhancement layers in frame 2 reference 
the base layer and second enhancement layer in previous frame 1. The base and 
enhancement layers in frame 3 reference the base layer and first enhancement layer 
in previous frame 2. Since the quality of an enhancement layer is higher than that 
20 of the base iayer, the PFGS coding scheme makes motion prediction as accurate as 
possible for any given video layer while maintaining coding efficiency. 

Residues resulting from the image frame prediction are defined as the 
difference between the original image and predicted image. When using the linear 
DCT transform, the DCT coefficients of predicted residues equal the differences 
25 between the DCT coefficients of the original image and the DCT coefficients of the 
predicted image. Since the coding scheme in Fig. 4 uses two reference layers for 
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the prediction, the coding scheme produces two sets of predicted DCT coefficients: 
(1) a first set of predicted DCT coefficients of the predicted image that is formed by 
referencing a low quality reference layer, such as the base layer, and (2) a second 
set of predicted DCT coefficients of the . predicted image that is formed by 
5 referencing a higher quality reference layer, such as an enhancement layer. For a _ 
convenience, the first set of DCT coefficients are called the Low Quality Predicted 
DCT (LQPD) coefficients and the second set of DCT coefficients are called the 
High Quality Predicted DCT (HQPD) coefficients. It is noted that in other coding 
schemes, more than two sets of predicted DCT coefficients might be generated. 
10 The expectation is that the HQPD coefficients will produce lower DCT 

residues, thereby resulting in more efficient coding, because the reference layer is 
of higher quality and hence closer to the original image. While this is true from a 
mean perspective, there are individual DCT residues in the HQPD coefficients that 
actually increase in comparison to DCT residues produced by referencing a lower 
15 quality layer (i.e., residues in the LQPD coefficients). The undesired increase is 
due to the motion between frames and other reasons, and results in a less efficient 
coding as more data are needed to encode the residues.. 

Figs. 11-17 present an example of how use of higher quality references may 
introduce unexpectedly high residues (in comparison to jower quality references). 
20 In this example, the data is selected from the 398 th block of the 3 rd frame of a 
sequence known as "Coastguard", a well-known MPEG test sequence. 

Fig. 11 illustrates a set of low quality predicted DCT (LQPD) coefficients of 
a predicted layer 400 that is predicted from a base layer in the 398 lh block of the 3 rd 
frame of the /'Coastguard" sequence. The predicted layer 400 contains LQPD 
25 coefficients for an 8x8 array of pixels. The LQPD coefficients are quantized prior 
to encoding into the bit-stream. 
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Fig. 12 shows a wredicted base layer 402 that is produced by quantizing the 
LQPD coefficients of F g. 11 with a quantized step of seven. The quantized DCT 
coefficients in layer 402 are compressed into the bit-stream of base layer using a 
coding process, such as variable length coding. The quantized LQPD coefficients 
5 in layer 402 are subsequently dequantized in order to determine how extensive the 
quantization errors are. The differences between the LQFD coefficients in layer 400 
and the dequantized LQPD coefficients in layer 402 form residues in the DCT 
domain. The DCT residues are compressed using bit-plane coding to form the bit- 
stream of the enhancement layers. The DCT residues are represented in binary 

1 0 numbers and hence can be coded as several bit-plane layers according to the binary 
value. The maximum number of bit-plane levels is set to the number of bits needed 
to represent the maximum residual value in binary format. 

Fig. 13 shows five enhancement layers 404, 406, 408, 410, and 412 that are 
used to encode the DCT residues resulting from the differences between the LQPD 

15 coefficients in layer 400 and the dequantized LQPD coefficients in layer 402. In 
this case, the maximum DCT residue is 16, which can be represented by a five-digit 
binary number "10000" and encoded Using the five enhancement layers 404-412. 
Consider the coefficients in location (1,1) of the 8x8 arrays. The LQPD coefficient 
of layer 400 is "36" and the dequantized LQPD coefficient of base layer 402 is 

20 "35". The difference is "1" (i.e., 36-35=1), which can be represented in a five-digit 
binary value as "00001". Accordingly, the locations (1,1) of each enhancement 
layers 404-4 1 2 collectively define the value "0000 1". 

Each DCT coefficient in the base layer is encoded with a sign bit. In the 
enhancement layers, the absolute residual values are encoded within the multiple 

25 layer structure and their sign bits are encoded once. The sign bit is separately 
encoded and thus the layer structure of Fig. 13 presents the absolute residual value 
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of the DCT coefficient. Generally, the sign bit of each residual value is encoded 
with one bit following the most significant layer. The binary "1" denotes a positive 
and binary "0" denotes a negative. For instance, the sign bit in location (3, 4) is 
encoded to "0" in the 1st enhancement layer 404 and the sign bit in location (1, 2) is 
. 5 encoded to "1" in the 2nd enhancement layer 406. . 

According to the layer structure in Fig. 13, the low enhancement layers (e.g., 
first and second enhancement layers 404 and 406) effectively encode the larger or 
more significant bits of the DCT residues. Consider, for example, the DCT residue 
corresponding to array location (1, 2), which is 8 (i.e., 43-35=8). This value is 
10 encoded as "01000", which results in a "1" bit in the second enhancement layer 
406. Similarly, a larger residue occurs at location (3,4), which causes a-"l" bit in 
the first enhancement layer 404. 

All DCT coefficients that are encoded in the base layer and one or more 
enhancement layers are collectively called "Encoded DCT" or "ECD" Suppose, 
.15 for example, the first enhancement layer 404 is encoded as a low enhancement 
layer. The ECD coefficients are the sum of DCT coefficients in the base layer 402 
and the first enhancement layer 404. 

Fi<>. 14 illustrates the encoded DCT coefficients 420 in the base layer 402 
and the first enhancement layer 404. Notice that the first enhancement layer 404 
20 has a single binary "1" at location (3,4) in the 8x8 array. This ".1" bit is the most 
significant bit in a five-bit number "lxxxx\ and thus represents the value 16. 
Adding 16 to the value. "0" in the corresponding location (3,4) of the base layer 402 
yields, an absolute encoded value of "16", as shown in the encoded layer 420 at 
location (3,4). Again,, the negative sign is dictated the following.one bit. In this 
25 case, the following bit is "0", indicating a negative. 
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Fig. 15 shows the low quality DCT residues in layer 430 that are derived 
from the differences between the LQPD coefficients in layer 400 (Fig. 1 1) and the 
ECD coefficients in layer 420 (Fig. 14). The residues range from a maximum 
absolute value of 15 in location (4,3) to a minimum absolute value of 0. 
5 Fig. 16 illustrates an exemplary set of high quality predicted DCT (HQPD) 

coefficients of a predicted enhancement layer 440 that is predicted from the second 
enhancement layer in the 398 th block of the 3 rd frame of the "Coastguard" sequence. 
Since the higher quality enhancement layer is used for reference, the predicted 
image is expected to be closer to the original image. As a result, the expectation is 

10 that the residues associated with the HQPD coefficients should be smaller than the 
residues associated with the LQPD coefficients, thereby enabling a higher coding 
efficiency. However, this is not always the case. 

Fig. 17 shows the high quality DCT residues in a layer 450 that are derived 
from the differences between the HQPD coefficients in layer 430 and the ECD 

15 coefficients in layer 420. Comparing high quality DCT residues with the low 
quality DCT residues in layer 430 (Fig. 15), it is evident that the residues vary 
widely. That is, there is fluctuation in residue values caused by the utilization of 
different quality layers as references. It is also evident thai not all individual high 
quality DCT residues are smaller than their counterpart low quality DCT residues. 

20 For instance, the high quality DCT residues of "29" and "10" at locations (2,1) and 
(1,2) are larger than the corresponding low quality DCT residues of "10" and "8", 
respectively. Moreover, the high quality DCT residue at location (2,1) is "29", 
which exceeds the encoding range allowed by residual four bit planes because the 
enhancement layer 1 is already formed as part of the bitstream. In this case, the 

25 coding efficiency will rapidly decrease due to poor luck that a good method results 
in exceeding the number of available bit planes. "While the mean square of the high 
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quality DCT coefficients is smaller than the mean square of the low quality DCT 
coefficients, there remain some individual DCT residues that fluctuate due to using 
different quality layers as references. 

5 Advance predicted Bit-Plane Coding To Improve Coding Efficiencies 

The video distribution, system 60 (Fig. 2) is configured to efficiently 
eliminate the fluctuation caused by using multiple prediction references of different 
quality. Ideally, to eliminate this fluctuation, the HQPD coefficients should also be 
encoded in. the base layer and low enhancement layers. However, in practice, only 
10. the LQPD coefficients are actually encoded in the base layer and low enhancement 
layers. Accordingly, to efficiently eliminate the fluctuation in residues, the HQPD 
coefficients are predicted from the DCT coefficients encoded in the base layer and 
enhancement layer. 

Accordingly, the video encoder 80 is configured to predict the HQPD 
15 coefficients from the DCT coefficients of two reference layers and the encoded 
DCT (ECD) coefficients. Although, the HQPD coefficients are not expressly 
available in the decoder 98, the DCT coefficients of the reference layers and the 
encoded DCT coefficients are available both in the encoder and in the decoder. As 
illustrated in Fig. 3, the encoder 80 and the decoder 98 are equipped with advance 
20 prediction bit-plane coders (ABPIC) 86 and 99, respectively, that perform the 
prediction of the HQPD coefficients for the bit-plane coding. 

The following discussion presents two possible methods for predicting 
coefficients that may be used to minimize or eliminate fluctuations in the residues. 
The first method is able to recover reconstructed image without loss. The second 
25 method will bring some, minor error to reconstructed images in all layers, but it is 
very suitable to real-time application due to low computational complexity. 
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A. Prediction Me th od 1 

To demonstrate how the HQPD coefficients are predicted, first consider the 
LQPD coefficients, which can be represented as follows: 

5 

LQPD = DCT Q - DCT t ( 1 ) 

where DCT Q denotes the DCT coefficients of the original image and DCT, denotes 
the DCT coefficients of the predicted image of a previous base layer after motion 
10 compensation. The reconstructed DCT coefficients encoded in base layer and low 
enhancement layer can be described as: 



ECD = \IlQPD]q]q 1 (2) 

15 The modular function [_*_^ denotes a complex quantization, which includes 

the scalar quantization in the base layer and the bit-plane quantization in the low 
enhancement layer. The modular function f*V' denotes an inverse quantization 
with respect to the complex quantization. The value Q is not only the quantized step 
in scalar quantization, but denotes quantized parameters including scalar 

20 quantization and bit-plane quantization. 

The HQPD coefficients are represented as follows: 



HQPD = DCT 0 - DCT h 



(3) 
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where DCT h denotes the DCT coefficients of the predicted image of a previous 
enhancement layer after motion compensation. 

To eliminate the residue fluctuation between low and high quality 
predictions, the coding scheme predicts an ECD value, ECD, that corresponds to 
5 the HQPD coefficients. 

ECD = [lHQPD\>\> (4) 

Integrating equations (1), (2) and (3) into, (4), a predicted. ECD value is 
10 obtained as follows: 

[iDCTo-DCT^Q 1 
[iDCTo- DCT t + (DCT! - DCT h )\^\ Q l 
\VECD + {LQPD - ECD) + (DCT, - DCT h )] Q \ 1 
[1{ECD + (DCT, - DCT^ + \LOPD - ECD}\<^\ Q } (5) 

From equation (5), the predicted value' ECD consists of two parts. The first 
term involves the encoded DCT value ECD and the DCT coefficients of two 
predicted images DCT, and DCT /r The elements in this first term are available at 

20 both the encoder 80 and the decoder 98. 

The second item is a quantized error corresponding to the LQPD coefficients 
that will be encoded in the high enhancement layers. This second item is not 
available for the decoder 98. However, its probability density distribution can be 
used to predict ECD, Two possible distributions that may be used are the 

25 Laplacian distribution and the Generalized Gaussian Density (GGD) distribution. 
For the Laplacian distribution, an article by R.CReininger and J.D.Gibson, entitled 



ECD = 



15 
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"Distribution of the two-dimensional DCT coefficients for images", IEEE trans, 
comm. Vol 31, 835-839, (1983) describes use of Kolmogrov-Smirnov tests to show 
that most DCT coefficients of images are reasonably well modeled as Laplacian 
distributions. GGD is described in an article by F.Muller, entitled "Distribution 
5 shape of two-dimensional DCT coefficients of natural image", Electron. Letter, Vol 
29, 1935-1936, (1993) where the author shows that modeling the DCT coefficients 
of images with the GGD function results in a significantly smaller test statistic % 2 
compared with Laplacian. 

The GGD distribution is more .preferred because the DCT coefficients of the 
10 inter frame can be modeled with zero-mean GDD. Recall that the Generalized 
Gaussian Density function is given as: 



/>(*) = 



1 5 where /;( v, a x ) = a ~ 



2T(\lv) 



exp(-f7(v,cr T )|^|]' (6) 



■ — 1 1 / ^ 
T{\!v) 



Here, a x is the standard deviation and v is a shape parameter. For a 
Gaussian density, the shape parameter is two (i.e., v=2.Q), while for a Laplacian 
distribution, the shape parameter is one (i.e., i/ = 1.0). A GGD source for a set of 
20 samples can be quickly and accurately modeled using derived parameters. This 
flexibility of the shape parameter v in the GGD shape allows for the efficient 
capture of diverse statistical characteristics of DCT coefficients. 

The formula (5) can be rewritten as the sum of sign X with a GGD 
distribution and a noise s with Gaussian distribution: 



BNSDOCI D- < WC „. 0 1 620 1 0A 1 I > 
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Y = X + s (7) 
where X = ECT + OCT, - DCT„ and e = LQPD - ECD 

5 

Because the noise e is an unknown variable for the decoder, the precise Y is 
unavailable at the decoder. The predicted value ECD is derived from an optimal 
quantizing Y with its statistic distributed properties, including steps of zero bin and 
non-zero bin. One issue concerns how to calculate the steps of zero bin and non- 
10 zero bin. 

where 9 is the optimal quantized parameter. 
15 The optimal quantization bins are those that cause the following distortion 

criterion to be minimized. 

r(T) = E y E nx (Y-X) 2 (9) 

20 where X ~ GGD y a (x) 

Y\X~N(x,a) 

The parameter a denotes the standard variance of sign c. Due to the 
generalized Gaussian distribution of A', a methodology described in an article by S. 
25 Grace Chang, Bin Yu and Martin Vetterli, entitled "Lossy Compression and 
Wavelet Thresholding for Image Denoising", which was submitted to IEEE 
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Transactions on Image I rocessing and is publicly available, obtains a near optimal 
threshold as follows: 



The step of zero bin equals two times T(v,cr A ) . Quantized Y is non-zero if it 
is larger than T; otherwise, it is set to zero. The parameter a can be estimated from 
sign e . The parameter <j x and v can be estimated from sign X according to a 
methodology described in an article by R.LJoshi and T.R.Fischer, entitled 
10 "Comparison of generalized Gaussian and Laplacian modeling in DCT image 
coding", IEEE signal processing letters, Vol 2, no 5, 81-82, (1995): 




(10) 



5 



15 



where m, 




m 




F(a) = 



r<2/a) 



VF(l/a)r(3/a) 



20 



The sign X is available both in the encoder 80 and in the decoder 98. The 
parameter o\ and wean therefore be calculated in the decoder 98 using the same 
methodology rather than transmitting them as pan of the bitstream. Although, the 
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parameter a can not be estimated in the decoder 98, some value with respect to 
each layer can be empirically derived. 

The non-zero bin can be determined by quantizing GGD random variables 
with a uniform threshold quantizer. Fig. 18 shows an exemplary uniform threshold 
5 quantizer 480, a center that represents the reconstructed level and non-zero bins 
with k levels of equal intervals of A on each side of the center. The reconstructed 
value of f\ with boundaries b/.j and bt is: 

I xp(x)clx 
**'/ ■ i 

r > = ~&- 

I P(x)dx 

10 

The predicted value ECD equals the dequantization of Y , or 

ECD -PrV-rLYj,V ( 12 > 

1 5 The parameter 6 is T for zero-bin; otherwise, it equals b, for non-zero bins. The 
above process can get an optimal predicted value ECD in a statistic sense that can 
efficiently eliminate the fluctuation. The DCT coefficients encoded in high 
enhancement layers are the differences between HQPD and predicted value ECD. 

In a special case, DCT residues will still fluctuate as little probability events. 

20 For example, X = ECT + DCT, rr DCT,, may be a value, which is smaller than the 
threshold T, but the value LQPD-ECD might still be close to the maximum value 
presented by residual bit planes. In such cases, the summary may exceed the 
maximum value by residual bit planes. Suppose the X equals 3, the predicted value 
ECD is zero because it is smaller than, threshold 6. If LQPD - ECD equals 15, the 

25 summary equals 18 which exceeds the encoding range 15 allowed by four residual 



(11) 
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bit planes. The solution for this case is to quantize LQPD-ECD forward to the 
low enhancement layer. 

For our example, a value LQPD-ECD of 15 can be represented in a five- 
digit binary value as "01111" and the most significant bit is in enhancement layer 
5 406. The value LQPD-ECD is quantized as 16 and its residue is Now the 

most significant bit of the value LQPD - ECD moves forward the enhancement 
layer 404. It means that in first enhancement layer, the value 16 is encoded and in 
the last enhancement layer, the value -1 is encoded. As a cost, the two sign bits are 
encoded in order to avoid the fluctuation exceeding the maximum range. As 

10 discussed above, the sign bit is encoded following the MSB. If two sign bits exists, 
the first sign bit is encoded in the low enhancement layer and the second sign bit is 
encoded in the layer modifying references. 

The two sign bits can be encoded with high efficiency with two prior 
conditions. Firstly, the second sign bit appears only in the coefficients in which the 

15 MSB is encoded in the low enhancement layer. Secondly, the second sign is 
identical to the first sign in most cases because the fluctuation exceeding the 
maximum range is a little probability event. 

predicted process is shown as follows: 
Set 

DCT lh = DCT ( - DCT h ADCT = ECD + (DCT { - DCT h ) 
Threshold: Th = 2* +l , k is index layer where changes reference. 
Q is scalar quantized parameter of base layer 
Optimal predict parameter : q = 0 
Predict 

(a) If ( ADCT - Q / 2) / (2*Q) o 0 



The 
20 (1) 



25 (2) 
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ECD = liADC7'J / J^ 

(b) If ( ADCT - Q / 2) / (2*Q) = 0 
(i) if (DCT lh >= Th) 

5 (ii)if(DCr M >=Th/2) 

if (£CD<> 0) 

iTCD = ADCT 
else (Q >= 20 and DCT lh > Th *3/4) 
ECD = ADCT 
10 (iii)if(DC7 M <Th/2) 

(3) if HQPD- £*CZ> exceeds the maximum range 
Adjusting the ECD, then goto (2); 

15 B. Prediction Method 2 

The second method based on advance predicted bit plane coding is that the 
base layer encodes the DCT coefficient with respect to scalar quantized LQPD. All 
enhancement layers encode differences between the HQPD coefficients and the 
dequantized LQPD coefficients. Note that the difference of this method is the DCT 

20 coefficients encoded in low. enhancement layers are derived from the HQPD 
coefficients, rather than the LQPD coefficients. This solution is low cost one in 
computational complexity because the expensive predict operations can be avoided 
during modifying references. .At the same time, some error will be resulted in low 
enhancement layers. In low enhancement layers, the difference between the HQPD 

25 coefficients and the dequantized LQPD coefficients replaces the difference between 
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the LQPD coefficients and the dequantized LQPD coefficients to be encoded and 
transmitted. This replac ement will introduce a small error. 

Although, some minor error will appear in low enhancement layer, it is 
fortunate that there is no error in the base layer. As a result, the minor error in low 
5 enhancement layers will only propagate within one or two frames due to the 
excellent properties in error recovery of PFGS. For instance, some error in the 
enhancement layer 104 of frame 2 in Fig 4 will only affect all enhancement layers 
of frame 3 and enhancement layer 106 and 108 of frame 4. This solution is very 
viable for real-time applications because the low cost in computational complexity. 

10 

Exemplary Encoders with Advance predicted Bit-Plane Coding 

Fig. 19 shows one exemplary implementation of a video encoder, which may 
be implemented by server 74 to encode the video data files prior to distribution over 
the network 64 as illustrated by encoder 80 in Fig. 3. In Fig. 19, the video encoder 

15 is generally referenced as number 80' to differentiate it from the encoder 80 of Fig. 
9. Like encoder 80 of Fig. 9, the video encoder 80' is configured to code video data 
according to a PFGS layered coding scheme. However, unlike the encoder 80, the 
video encoder 80' predicts the HQPD coefficients and encodes high quality 
residues based on the HQPD coefficients to remove or reduce residue fluctuations, 

20 thereby improving coding efficiency. 

Video encoder 80' is designed to use multiple reference layers for image 
prediction. In particularly, the illustrated architecture implements the PFGS layered 
coding scheme of Fig. 4, in which two reconstructed layers are used for reference. 
The video encoder 80' employs two frame buffers 502 and 504, which offers a 

25 good tradeoff between coding efficiency and the additional cost in memory and 
computational complexity. A first frame buffer 502 is used to save the 
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reconstructed base layer as a reference for the base layer and low enhancement 
layers of a predicted frame. A second frame buffer 504 is used to save a 
reconstructed enhancement layer in a previous frame as a reference for higher 
quality enhancement layers. 
5 Video encoder 80' has a base layer encoder 506 that encodes the base layers 

into an encoded bitstream and two enhancement layer encoders 508 and 509 that 
encodes one or more enhancement layers into the encoded bitstream. The video 
encoder also has an advance prediction bit-plane coder (APBIC) 510 that generates 
the first term of the predicted encoded value ECD , given in equation (5). The 
10 predicted encoded value ECD provides a good prediction of the HQPD 
coefficients. 

The video encoder 80* receives a video data input stream and directs the 
incoming image frames to a motion estimator 204 to estimate movement of objects 
in the frame. The motion estimator 204 receives as reference for the current input, 

15 a previous reconstructed frame stored in frame buffer 502. The motion estimator 
204 outputs its results to two motion compensator 206 and 207, which in turn 
produce predicted images. The first motion compensator 206 predicts images by 
referencing the reconstructed base layer in frame buffer 502. The second motion 
compenstator 207 predicts images by referencing a reconstructed enhancement 

20 layer in frame buffer 504. Although two compensators are illustrated, they may be 
integrated as a single component. The motion estimator 204 and motion 
compensators 206, 207 are well-known components used in conventional MPEG 
encoding. 

The differences between the low quality base layers of the predicted image 
25 and the original image are computed at summation 520. The differences are 
transformed using a linear discrete cosign transformation (DCT) 522 to produce the 
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low quality predicted DCT (LQPD) residues resulting from the motion 
compensation, as described above by equation (1). The LQPD coefficients are 
quantized by quantizer (i.e., the "Q" module) 524 and compressed by the variable 
length coder (VLC) 526 into the bitstream of the base layer. 
5 The quantized LQPD coefficients output by quantizer 524 are also 

dequantized by the dequantizer (i.e., the "Q" 1 " module) 528. The dequantized 
LQPD coefficients are passed through an inverse DCT (IDCT) 530 to reconstruct 
the base layer. The reconstructed base layer is stored in frame buffer 502. 

The enhancement layer encoder 508 receives the LQPD coefficients (e.g., 

10 coefficients in layer 400) and the dequantized LQPD coefficients (e.g., the 
coefficients in layer 402) from the base layer encoder 506. The differences between 
these coefficients are computed at summation 540 to form the DCT residues that 
can be encoded using bit-plane coding into the bitstream of the enhancement layers, 
as illustrated in Fig. 13. The "find max" module 542 computes the maximum value 

15 of all absolute values in the DCT residues to determine the number of bit planes 
needed to represent the residues. The DCT residues are then encoded into multiple 
bit planes by a bit plane coder 544 and then compressed by the variable length 
coder (VLC) 546 into the bitstream of the enhancement layer. Although multiple 
VLCs are illustrated, it is noted that a common VLC may be used for all 

20 compression being performed on the base layer and enhancement layer data. 

A summation 550 sums the DCT residues contained in one or more bit 
planes, as output from the bit plane coder 544, and the dequantized LQPD 
coefficients from the base layer encoder 506. This is essentially the operation 
illustrated in Fig. 14, where the dequantized DCT coefficients of the base layer 402 

25 are added to the first enhancement layer 404 to produce encoded DCT (ECD) 
coefficients 420. An inverse DCT 552 computes an inverse transform on the ECD 
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coefficients to reconstruct an enhancement layer. The reconstructed enhancement 
layer is summed at summation 554 with either a predicted base layer from the 
motion compensator 206 or a predicted enhancement layer from the motion 
compensator 207, depending upon the position of switch 556. 
5 The differences between the high quality enhancement layers of the 

predicted image and the original image are computed at summation 560. The 
differences are transformed using a DCT transformation 562 to produce the high 
quality predicted DCT (HQPD) residues resulting from the motion compensation, 
as described above by equation (3). The HQPD coefficients are input to a 
10 summation 564. 

The advance prediction bit-plane coder 510 receives the base layer from 
motion compensator 206, the enhancement layer from the motion compensator 207 
and the ECD coefficients from summation 550. DCT modules 570 and 572 
transform the base layer and . enhancement layers to produce DCT coefficients, 
1 5 which are then input along with the ECD coefficients to the prediction module 574. 

The prediction module 574 computes the first term of the predicted value 
ECD in equation (5), which includes the ECD coefficients and the DCT 
coefficients of two predicted images DCT, and DCT,,. The output of the prediction 
model 574 is the predicted HQPD coefficients. 
20 The summation 564 computes differences between the HQPD coefficients 

and the first terms of the predicted value ECD to produce a set of high quality DCT 
. residues. This is. essentially the operation illustrated in Fig, 1 7, with the exception 
that the encoded DCT layer contains predicted ECD. coefficients. The high quality 
DCT residues output by the summation 564 exhibit smaller residues and 
25. significantly less fluctuation. , ;. : , 
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A "find max" nodule 580 computes the maximum value of all absolute 
values in the high qmiity DCT residues to determine the number of bit planes 
needed to represent the residues. The high quality DCT residues are then encoded 
into multiple bit planes by a bit plane coder 582 and compressed by the variable 
5 length coder (VLC) 584 into the bit-stream of the enhancement layer. 

Fig. 20 shows the complementary video decoder 98', which may be 
implemented by client 66, to decode the video data files received over the network 
64 (Fig. 3). The decoder 98' has a bit layer decoder 602 that decodes the bitstream 
for the base layers and two enhancement layer decoders 604 and 606 that decode 

10 the bitstream to recover the enhancement layers. The decoder 98' also has an 
advance prediction bit-plane coder (APBIC) 610, that is essentially identical to the 
encoder-side APBIC 5 1 0 in Fig. 1 9. 

A variable length decoder (VLD) module 620 decodes the bit stream for the 
base layer to recover the quantized LQPD coefficients. Motion vectors (MVs) from 

1 5 the decoding are passed to motion compensators 622 and 624. These coefficients 
are dequantized by a dequantizer (i.e., the "Q" 1 " module) 626 and then passed 
through an inverse DCT (IDCT) transform 628 to reconstruct the base layer. The 
reconstructed base layer is summed via summation 630 with a predicted base layer 
from the motion compensator 622, clipped by clipping module 632, and output. 

20 The reconstructed base layer is also stored in frame buffer 634. 

A combined VLD and bit plane decoder module 640 decodes the bit stream 
carrying the lower quality DCT residues. The recovered DCT coefficients are 
summed via summation 642 with the dequantized LQPD coefficients from the base 
layer decoder 602 to reproduce the encoded DCT (ECD) coefficients. The ECD 

25 coefficients are passed to an IDCT transformer 644 to reconstruct the enhancement 
layer. The reconstructed enhancement layer is summed via summation 646 with 
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either a predicted base layer from the motion compensator 622 or a predicted 
enhancement layer from the motion compensator 624, depending upon the position 
of switch 648. The compensated enhancement layer is clipped by clipping module 
650 and output. The reconstructed enhancement layer is also stored in frame buffer 
5 652. 

The prediction bit-plane coder 610 receives the base, layer from motion 
compensator 622, the enhancement layer from the motion compensator 624 and the 
ECD coefficients from summation 642, DCT modules 660 and 662 transform the 
base layer and enhancement layers to produce DCT coefficients, which are then 
10 input along with the ECD coefficients to the prediction module 664. The prediction 
module 664 computes the first term of the predicted value ECD in equation (5), 
which includes the ECD coefficients and the DCT coefficients of two predicted 
images DCTi and DCT h . 

A combined VLD and bit plane decoder module 670 decodes the bit stream 
15 carrying the higher quality DCT residues. The summation 672 sums the high 
quality DCT residues and the first terms of the predicted value ECD to produce the 
HQPD coefficients. An inverse DCT transformer 674 reconstructs the enhancement 
layer from the HQPD coefficients. The reconstructed enhancement layer is 
compensated by the output of the motion compensator 624 at summation 676, and 
20 then clipped by clipping module 678. 

Fig. 21 shows another exemplary video encoder 80" that is based on the 
advance predicted bit-plane coding, scheme, but is a simplified version of the 
encoder 80' of Fig. 19. Namely, unlike encoder 80\ the video encoder 80" of Fig. 
21 is modified so that the DCT residues encoded in the enhancement layer equal the 
.25 differences between the HQPD coefficients and the reconstructed DCT coefficients 
of the base layer. All enhancement layers encode the residues between the HQPD 
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coefficients and the dequantized coefficients in base layer. As a result, no 
prediction is used. This encoder 80" is therefore a low cost solution in terms of 
computational complexity because the expensive prediction operations are 
removed. 

5 However, some error is resulted in the enhancement layers. In low 

enhancement layers, the difference between the HQPD coefficients and the ECD 
coefficients, rather than between the LQPD and ECD coefficients, will introduce 
some error during encoding. Fortunately, the error is contained because there is no 
error in the base layer. The error in the enhancement layers will only propagate 
10 within one or two frames because the excellent properties in error recovery of 
PFGS. The second solution is very available for real-time applications because the 
low cost in computational complexity. 

Fig 22 shows the complementary video decoder 98' * that corresponds to the 
video encoder 80" of Fig. 21. 

15 

Exemplary Coding Operation 

Fig. 23 shows an exemplary video coding process implemented by the video 
encoders 80 5 and 80 " of Figs. 19 and 21, respectively. The video coding process 
may be implemented in hardware, software, or a combination of hardware and 
20 software. The process is described with additional reference to the encoders of 
Figs. 19 and 21. 

The process can be generally described as the combined operations of the 
base layer encoder 506, the low quality enhancement layer encoder 508, and the 
high quality enhancement layer encoder 509. At step 700, the base layer encoder 
25 506 encodes a bitstream representing a base layer. At step 702, the low quality 
enhancement layer encoder 508 encodes a bitstream representing a low quality 
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enhancement layer. This is done by encoding low quality residues that result from 
the low quality prediction of motion compensated images. At step 704, the high 
quality enhancement layer encoder 509 encodes a bitstream representing a high 
quality enhancement layer based in part on values predicted from the base layer and 
5 the low quality enhancement layer. This can be accomplished by encoding 
predicted high quality residues that are predicted in. part from the low quality 
residues. The bitstreams can be stored on disk and/or transmitted over the network 
to the client. 

Steps 710-716 show one sub-process for implementing the base layer 
10 encoding step 700. At step 71 Q, the base layer encoder 506 predicts a low quality 
predicted image from a low quality reconstructed layer stored in the frame buffer 
502. This predicted image varies slightly from the original image due to motion of 
the objects in the images as determined by the motion estimator 204 and the motion 
compensator 206. 

15 At step 712, the base layer encoder 506 transforms the low quality predicted 

image using a transformation, such as the linear Discrete Cosine Transform 522, to 
produce low quality predicted DCT (LQPD) cqefficients. The LQPD coefficients 
are quantized by . quantizer 524 (step 714) and compressed by the variable length 
coder 526 (step 716). 

20 Steps 720-726 illustrate one siib-prpcess : for implementing the low quality 

enhancement layer encoding step 702. At step 720, the base layer encoder 506 
dequantizes the quantized LQPD coefficients. The low quality enhancement layer 
encoder 508 derives low quality residues resulting from prediction of the low 
quality image (step 722). The low quality residues are computed as the difference 

25 between the LQPD coefficients and .the; dequantized LQPD coefficients. 
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At step 724, the k w quality residues are encoded via bit plane coder 544 to 
form the encoded DCT (BCD) coefficients. At step 726, the low quality 
enhancement layer encoder 508 compresses the ECD coefficients using variable 
length coder 546. 

5 Steps 730-742 illustrate one sub-process for implementing the high quality 

enhancement layer encoding step 704. At step 730, the high quality enhancement 
layer encoder 509 predicts a high quality predicted image from a high quality 
reconstructed layer stored in the second frame buffer 504. This predicted image 
varies slightly from the original image due to motion of the objects in the images as 

10 determined by the motion estimator 204 and the motion compensator 207. At step 
732, the high quality enhancement layer encoder 509 transforms the high quality 
predicted image using a transformation, such as the linear Discrete Cosine 
Transform 562, to produce high quality predicted DCT (HQPD) coefficients. 

At this point, the process is slightly different depending upon whether 

1 5 encoder 80' of Fig. 1 9 is used or encoder 80" of Fig. 2 1. If encoder 80' is used, the 
APBIC 510 predicts a set of predicted HQPD coefficients from the ECD 
coefficients (step 734). The high quality enhancement layer encoder 509 then 
derives high quality residues as a difference between HQPD coefficients and the 
predicted HQPD coefficients (step 736). 

20 Conversely, if encoder 80" is used, the APBIC 5 1 0 is removed. Accordingly, 

the high quality enhancement layer encoder 509 derives high quality residues as a 
difference between the HQPD coefficients and the ECD coefficients (step 738). 

At step 740, the high quality enhancement layer encoder 509 encodes the 
high quality residues via bit plane coder 582. The coded high quality residues are 

25 then compressed using variable length coder 584 (step 742). 
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The client receives the bitstreams from the content provider. The video 
decoder at the client decodes the bitstreams to recover the base layer, low quality 
residues, and high quality residues. From this data, the decoder can recapture the 
original video image. 

Conclusion 

Although the invention has been described in language specific to structural 
features and/or methodological steps, it is to be understood that the invention 
defined in the appended claims is not necessarily limited to the specific features or 
10 steps described. Rather, the specific features and steps are disclosed as preferred 
forms of implementing the claimed invention. 
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CLAIMS 

1. A method for coding video data according to layered coding 
techniques in which the video data is represented as multi-layered frames, each 
frame having multiple layers ranging from a base layer of low quality to 

5 enhancement layers of increasingly higher quality, the method comprising: 
encoding a first bitstream representing a base layer; 

encoding a second bitstream representing one or more low quality 
enhancement layers; and 

encoding a third bitstream representing one or more high quality 
10 enhancement layers based in part on values predicted from the base layer and the 
low quality enhancement layer. 

2. A method as recited in claim 1 , wherein the encoding a first bitstream 
representing a base layer comprises: 

15 motion compensating an original image using the base layer as a reference to 

form a low quality predicted image; 

transforming the low quality predicted image to form low quality predicted 
coefficients; 

quantizing the low quality predicted coefficients to form quantized 
20 coefficients; and 

compressing the quantized coefficients using variable length coding. 

3. A method as recited in claim 1, wherein the encoding a second 
bitstream representing one or more low quality enhancement layers comprises: 

25 motion compensating an original image using the base layer as a reference to 

form a low quality predicted image; 
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transforming the low quality predicted image to form low quality predicted 
coefficients; 

quantizing the low quality ; predicted coefficients to form quantized 
coefficients; 

5 dequantizing the quantized coefficients to form dequantized coefficients; 

deriving low quality residues as a difference between the low quality 
predicted coefficients and the dequantized coefficients- 
bit plane coding the low quality residues to form coded low quality residues; 

. and 

10 compressing the coded low quality residues using variable length coding. 

4. A method as recited in claim 3, wherein the encoding a third bitstream 
representing one or more high quality enhancement layers comprises: 

motion compensating an original image using an enhancement layer as a 
15 reference to form a high quality predicted image; 

transforming the high quality predicted image to form a first set of high 
quality coefficients; ; : : 

predicting a second set of high quality coefficients from the coded low- 
quality residues; 

20 deriving high quality residues as a difference between the first and second 

sets of high quality coefficients; 

bit plane coding the high quality residues; and 

compressing the coded high-quality residues using variable length coding. 
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5. A method ;ts recited in claim 1, wherein the encoding a second 
bitstream representing one or more low quality enhancement layers and the 
encoding a third bitstream representing one or more high quality enhancement 
layers comprises: 

5 motion compensating an original image using the base layer as a reference to 

form a low quality predicted image and using an enhancement layer as a reference 
to form a high quality predicted image; 

transforming the low quality predicted image to form low quality predicted 
coefficients and transforming the high quality predicted image to form high quality 
1 0 predicted coefficients; 

quantizing the low quality predicted coefficients to form quantized 
coefficients; and 

dequantizing the quantized coefficients to form dequantized coefficients; 

deriving low quality residues as a difference between the high quality 
1 5 predicted coefficients and the dequantized coefficients; 

bit plane coding the low quality residues to form coded low quality residues; 

deriving high quality residues as a difference between the high quality 
predicted coefficients and the coded low quality residues; 

bit plane coding the high quality residues to form coded high quality 
20 residues; and 

compressing the coded low quality residues and the coded high quality 
residues using variable length coding. 

6. A method as recited in claim 1, further comprising: 
25 decoding the first bitstream representing the base layer; 
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decoding the second bitstream representing one or more low quality 
enhancement layers; and 

decoding the third bitstream representing one or more the high quality 
enhancement layers based in part on values predicted from the base layer and the 
5 low quality enhancement layer. • , 

7. A computer-readable medium having computer-executable 
instructions, which when executed on a processor, direct a computer to perform the 
steps of claim 1 . 

10 

8. A method for coding video data according to layered coding 
techniques in which the video data is represented as multi-layered frames, each 
frame having multiple layers ranging from a base layer of low quality to 
enhancement layers of increasingly higher quality, the method comprising: 

15 encoding a base layer and one or more low quality enhancement layers of a 

current frame that is predicted from a base layer of a previous frame; 

encoding low quality residues resulting from prediction of the base layer and 
the low quality enhancement layer; 

encoding high quality residues that are derived from the low quality residues. 

20 

9. A method. as recited in claim 8, wherein the encoding high quality 

residues comprises: 

predicting one or more high quality enhancement layers of the current frame 
from a high quality enhancement layer of the previous frame; 
25 transforming the high quality enhancement layer to form a first set of high 

quality coefficients; 
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predicting a second set of high quality coefficients from the low quality 
residues; and 

forming the high quality residues from the first and second sets of high 
quality coefficients. 

5 

10. A method as recited in claim 8, wherein the encoding high quality 
residues comprises: 

predicting a high quality enhancement layer of the current frame from a high 
quality enhancement layer of the previous frame; 
10 transforming the high quality enhancement layer to form high quality 

coefficients; and 

forming the high quality residues from the high quality coefficients and the 
low quality residues. 

15 11. A computer-readable medium having computer-executable 

instructions, which when executed on a processor, direct a computer to perform the 
steps of claim 8. 

12. A method for coding video data according to layered coding 
20 techniques in which the video data is represented as multi -layered frames, each 
frame having multiple layers ranging from low quality to increasingly higher 
quality, the method comprising: 

predicting layers in a current frame using multiple layers of varying quality 
in a previous frame; 

25 deriving low quality predicted residues from a low quality layer in the 

current frame and a low quality layer in the previous frame; 
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encoding the low quality predicted residues; and 

predicting, from the encoded low quality residues, high quality predicted 
residues representative of differences between a high quality layer in the current 
frame and a high quality layer in the previous frame. 

5 

13. A method as recited in claim 12, wherein the predicting layers 
comprises predicting a higher quality layer in the current frame from a lower quality 
layer in the previous frame. 

10 14; A method as recited in claim 12, wherein the encoding comprises 

quantizing the low quality predicted residues to produce quantized residues and 
compressing the quantized residues using variable length coding. 

15. A method as recited in claim 12, wherein the encoding comprises bit 
15 plane coding the low quality predicted residues. 

16. A method as recited in claim 12, wherein the predicting high quality 
predicted residues comprises computing a predicted value based on the encoded 
low quality residues and two predicted images. 

20 ■/-■..-■.'-•;..::■- 

17. A method as recited in claim 12, wherein the predicting high quality 
predicted residues comprises computing a predicted value based on two predicted 
images and an estimation of one of the two predicted images. 
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1.8. A compiler-readable medium having computer-executable 
instructions, which when executed on a processor, direct a computer to perform the 
steps of claim 12. 

5 19. A method for coding video data according to layered coding 

techniques in which die video data is represented as multi-layered frames, each 
frame having multiple layers ranging from a base layer of low quality to 
enhancement layers of increasingly higher quality, the method comprising: 

forming a base layer and multiple enhancement layers in a first frame 
10 representing an original image; and 

predicting, from the base layer and at least one enhancement layer in the first 
frame, a base layer and multiple enhancement layers in a second frame representing 
a predicted image; and 

deriving low quality residues resulting from the predicting of the base layer 
1 5 and low quality enhancement layers from the original image; 
encoding the low quality residues; and 

predicting, from the encoded sow quality residues, high quality residues 
indicative of results from predicting high quality enhancement layers from the 
original image. 

20 

20. A method as recited in claim 19, wherein the multiple enhancement 
layers include at least first, second, and third layers, and the forming of the multiple 
enhancement layers comprises predicting even frames from the base and second 
layers of preceding frames and predicting odd frames from the base and third layers 
25 of preceding frames. 
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21. A method as recited in claim 19, wherein the forming of the multiple 
enhancement layers comprises predicting each of the enhancement layers in a 
current frame from a lower quality reference layer of a reference frame if a 
relationship holds true, the relationship being: 

5 

L mod N = i mod M . ' . 

where I is a variable designating a particular enhancement layer, i is a variable 
designating a particular frame, N is a variable representing a layer group depth of 
10 how many layers are predicted from a common reference layer, and M is a variable 
representing a frame group depth of how many frames are grouped together for 
prediction purposes. 

22. A method as recited in claim 19, further comprising encoding the 
15 high quality residues. 

23. A method as recited in- claim 22, further comprising transmitting the 
encoded low quality residues and the high quality residues. 

20 24. A computer-readable medium having computer-executable 

instructions, which when executed on a: processor, direct a computer to perform the 
steps of claim 19. 

25. A method comprising:- 
25 encoding video data into multi-layered frames, where each frame includes a 

base layer of low quality, a low quality enhancement layer, and one or more higher 
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quality enhancement layers of increasingly higher quality, wherein the encoding of 
a higher quality enhancement layer is based in part on values predicted from the 
base layer and the low quality enhancement layer; and 

transmitting the base layer, the low quality enhancement layer, and the one 
5 or more higher quality enhancement layers over a network. 



26. A method as recited in claim 25, further comprising: 

receiving the base layer, the low quality enhancement layer, and the one or 

more higher quality enhancement layers from the network; and 
10 decoding the base layer, the low quality enhancement layer, and the one or 

more higher quality enhancement layers to recover the video data. 



27. A computer-readable medium having computer-executable 
instructions, which when executed on a processor, direct a computer to: 
15 predict a low quality layer of a current frame of video data from a low 

quality layer of a previous frame; 

encode the low quality layer; 

derive low quality residues resulting from prediction of the low quality layer; 

encode the low quality residues; 
20 predict a high quality layer of a current frame of video data from a high 

quality layer of a previous frame; 

derive high quality residues from the high quality layer and the low quality 
residues; and 

encode the high quaiity residues. 
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28. A computer-readable medium having computer-executable 
instructions, which when executed on a processor, direct a computer to: 
(A) encode a first bitstream representing a base layer by: 

motion compensating an original image using a base layer as a 
5 reference to form a low quality predicted image; 

transforming the low quality predicted image to form low quality 
predicted coefficients; and 

quantizing the low quality predicted coefficients to form quantized 
coefficients; 

10 (B) encode a second bitstream representing a low quality enhancement layer 

by: . . .... 

dequantizing the quantized coefficients to form dequantized 

coefficients; 

deriving low quality residues as a difference between the low 
1 5 quality predicted coefficients and the dequantized coefficients; and 

bit plane coding the low quality residues to form coded low 
quality residues; 

(C) encode a third bitstream representing a high quality enhancement layer 

by: 

20 motion compensating an original image using an enhancement 

layer as a reference to form a high quality predicted image; 

transforming the high quality predicted image to form a first set of 
high quality coefficients; 

predicting a second set of high quality coefficients from the coded 
25 low quality residues; 
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deriving high quality residues as a difference between the first and 
second sets of high quality coefficients; and 
bit plane coding the high quality residues. 



5 29. A computer-readable medium as recited in claim 28, further 

comprising computer-executable instructions, which when executed on a processor, 
direct a computer to compress the quantized coefficients, the coded low quality 
residues, and the coded high quality residues using variable length coding. 

10 30. A computer-readable medium having computer-executable 

instructions, which when executed on a processor, direct a computer to: 
(A) encode a first bitstream representing a base layer by: 

motion compensating an original image using a base layer as a 
reference to form a low quality predicted image; 
15 transforming the low quality predicted image to form low quality 

predicted coefficients; and 

quantizing the low quality predicted coefficients to form quantized 
coefficients; 

(B) encode second and third bitstreams representing a low quality 
20 enhancement layer and a high quality enhancement layer by: 

dequantizing the quantized coefficients to form dequantized 
coefficients; 

motion compensating the original image using an enhancement 
layer as a reference to form a high quality predicted image; 
25 transforming the high quality predicted image to form high quality 

predicted coefficients; 
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deriving low quality residues from the high quality predicted 
coefficients and the dequantized coefficients; 

bit plane coding the low quality residues to form coded low 
quality residues; 

5 deriving high quality residues from the high quality predicted 

coefficients and the coded low quality residues; and 

bit plane coding the high quality residues to form coded high 
quality residues. 

10 31. A computer-readable medium as recited in claim 30, further 

comprising computer-executable instructions, which when executed on a processor, 
direct a computer to compress the quantized coefficients, the coded low quality 
residues, and the coded high quality residues using variable length coding. 

15 32. A video coding system, comprising: 

a base layer encoder to encode a bitstream representing a base layer of video 

data; , 

a low quality enhancement layer encoder to encode a bitstream representing 

one or more low quality enhancement layers; apd 
20 a high quality enhancement layer encoder to encode a bitstream representing 

one or more high quality enhancement layers based in part on values predicted 
from the base layer and the low quality enhancement layer. 
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33. A video coding system as recited in claim 32, further comprising a 
prediction module to predict the values from the base layer and the low quality 
enhancement layer. 

5 34. A video coding system as recited in claim 32, further comprising: 

a first frame buffer to hold a reconstructed base layer; 
a second frame buffer to hold a reconstructed enhancement layer; and 
the base layer encoder being configured to motion compensate an original 
image using the reconstructed base layer in the first frame buffer as a reference to 
10 form a low quality predicted image and to transform the low quality predicted 
image to form low quality predicted coefficients that may be coded into the 
bitstream representing a base layer of video data; 

the low quality enhancement layer encoder being configured to derive low 
quality residues from the low quality predicted coefficients and to code the low 
1 5 quality residues to form coded low quality residues for the bitstream representing a 
low quality enhancement layer; 

the high quality enhancement layer encoder being configured to motion 
compensate the original image using the reconstructed enhancement layer in the 
second frame buffer as a reference to form a high quality predicted image and to 
20 transform the high quality predicted image to form high quality predicted 
coefficients; and 

a prediction module to predict high quality residues from the high quality 
predicted coefficients and the coded low quality residues. 
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35. A video coding system as recited in claim 34, wherein the high 
quality enhancement layer encoder is configured to code the predicted high quality 
residues for the bitstream representing a high quality enhancement layer. 

5 36. An operating system comprising the video coding system of claim 32. 

37. A video coding system, comprising: 

multiple frame buffers to hold reconstructed layers of a previous frame of an 
image, the reconstructed layers ranging in quality from low quality to high quality; 

a low quality layer encoder to predict a low quality predicted image from a 
low quality reconstructed layer in one of the frame buffers and derive low quality 
residues resulting from the prediction, the low quality layer encoder being 
configured to encode the low quality predicted image and the low quality residues 
into one or more bitstreams; 

a high quality layer encoder to predict a high quality predicted image from a 
high quality reconstructed layer in another of the frame buffers; 

a prediction module to predict high quality residues from the high quality 
predicted image and the coded low quality predicted image; and 

the high quality layer encoder being configured to encode the high quality 
residues into a bitstream. 

38. An operating system comprising the video coding system of claim 37. 

39. A video coding system, comprising: 

25 multiple frame buffers to hold reconstructed layers of a previous frame of an 

image, the reconstructed layers ranging in quality from low quality to high quality; 
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a low quality layer encoder to predict a low quality predicted image from a 
low quality reconstructec: layer in one of the frame buffers and derive low quality 
residues resulting from the prediction, the low quality layer encoder being 
configured to encode the low quality predicted image and the low quality residues 

5 into one or more bitstreams; 

a high quality layer encoder to predict a high quality predicted image from a 
high quality reconstructed layer in another of the frame buffers and derive high 
quality residues from the high quality predicted image and the coded low quality 
predicted image, the high quality layer encoder being configured to encode the high 

10 quality residues into a bitstream. 

40. An operating system comprising the video coding system of claim 39. 

41. A video coding system, comprising: 

15 means for predicting layers in a current frame using multiple layers of 

varying quality in a previous frame; 

means for deriving low quality predicted residues from a low quality layer in 
the current frame and a low quality layer in the previous frame; 

means for encoding the low quality predicted residues; and 
20 means for predicting, from the encoded low quality residues, high quality 

predicted residues representative of differences between a high quality layer in the 
current frame and a high quality layer in the previous frame. 



42. An operating system comprising the video coding system of claim 41. 
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43. A video coding system, comprising: 

means for forming a base layer and multiple enhancement layers in a first 
frame representing an original image; and . 

means for predicting, from the base layer, and at least one enhancement layer 
5 in the first frame, a base layer and multiple enhancement layers in a second frame 
representing a predicted image; and 

means for deriving low quality residues resulting from the predicting of the 
base layer and low quality enhancement layers from the original image; 

means for encoding the low quality residues; and 
10 means for predicting, from the encoded low quality residues, high quality 

residues indicative of results from predicting high quality enhancement layers from 
the original image. 



44. An operating system comprising the video coding system of claim 43. 

45. A video delivery architecture, comprising: 

a content provider having a video storage to store the video data and a video 
server to serve the video data over a network, the video server being configured to 
encode the video data into multi-layered, frames where each frame includes a base 
20 layer of low quality, a low quality enhancement layer, and one or more higher 
quality enhancement layers of increasingly higher. quality, the video server encoding 
a higher quality enhancement layer based in part on values predicted from the base 
layer and the low quality enhancement layer; and 

a client configured to receive the encoded video data served from the content 
25 provider, the client being configured to decode the video data. 
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